const path = require("path");
const htmlWebpackPlugin = require("html-webpack-plugin");
const vueLoaderPlugin = require("vue-loader/lib/plugin");

module.exports = {
    entry: path.join(__dirname, "./src/main.js"),
    output: {
        path: path.join(__dirname, './dist'),
        filename: "bundle.js"
    },
    module: {
        rules: [
            { test: /\.css$/, use: ['style-loader', 'css-loader'] },
            { test: /\.less$/, use: ['style-loader', 'css-loader', 'less-loader'] },
            { test: /\.scss$/, use: ['style-loader', 'css-loader', 'sass-loader'] },
            { test: /\.(jpg|png|gig|bmp|jpeg)$/, use: ['url-loader?limit=1000&name=[hash]-[name].[ext]'] },
            { test: /\.(eot|svg|ttf|woff|woff2)$/, use: ['url-loader'] },
            { test: /\.js$/, use: ['babel-loader'], exclude: /node_modules/ },
            { test: /\.vue$/, use: ['vue-loader'] }
        ]
    },
    plugins: [
        new htmlWebpackPlugin({
            template: path.join(__dirname, "./src/index.html"),
            filename: "index.html"
        }),
        new vueLoaderPlugin()
    ],
    mode: "development",
    devServer: {
      port: 3001,
      open: true,
      hot: true,
      contentBase: path.join(__dirname, './src'),
      historyApiFallback: true,
      host: '127.0.0.1',
      disableHostCheck: true,
      noInfo: true
    }
}